package woa.binarysearch;

/**
 * 有效的完全平方数
 * 给定一个 正整数 num ，编写一个函数，如果 num 是一个完全平方数，则返回 true ，否则返回 false 。
 *
 * 输入：num = 16
 * 输出：true
 *
 * @author wangpeng
 * @date 2021/12/21
 */
public class PerfectSquare {

    public static boolean isPerfectSquare(int num) {
        if (num == 1) {
            return true;
        }
        int left = 0, right = num;
        while (left <= right) {
            int mid = left + (right - left) / 2;
            double target = (double)num / mid;
            if (target == mid) {
                return true;
            }
            if (target < mid) {
                right = mid - 1;
            } else {
                left = mid + 1;
            }
        }

        return false;
    }

    public static void main(String[] args) {
        System.out.println(isPerfectSquare(5));
    }

}
